#define _CRT_SECURE_NO_WARNINGS

#include<stack>

class MinStack {
public:
    MinStack() {

    }

    void push(int val) {
        st.push(val);
        if (minSt.empty() || val <= minSt.top())
        {
            minSt.push(val);
        }
    }

    void pop() {
        int val = st.top();
        st.pop();
        if (!minSt.empty() && val == minSt.top())
        {
            minSt.pop();
        }
    }

    int top() {
        return st.top();
    }

    int getMin() {
        return minSt.top();
    }
private:
    stack<int> st;
    stack<int> minSt;
};
